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CLAIMS 



What is claimed is: 

1. A microprocessor, comprising: 

a microcode unit for outputting control signals, for each of a plurality 
of instructions, required by said microprocessor for executing said 
instructions, the microcode unit comprising: 

an instruction address input for receiving an instruction 

address; 

a control variable input for receiving a control variable 
corresponding to a current state of the microprocessor; 

a control signal input for receiving all the control signals output 
by the microcode unit for an immediately preceding instruction; and 

a plurality of embedded logic circuits each dedicated for 
evaluating one unique type of instruction received by the microcode unit. 

2. The microprocessor according to claim 1, wherein each of the embedded 
logic circuits includes: 

a table for performing a table lookup in response to a received 
instruction; and 

a controller responsive to the control variable, the control 
signals for an immediately preceding instruction, and to the table lookup for 
controllably setting each of the control signals required by the microprocessor 
for executing said received instruction. 

3. The microprocessor of claim 2, wherein the controller includes: 

means for setting a control signal to a "1" regardless of its immediately 
preceding value; 

means for setting a control signal to a "0" regardless of its immediately 
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preceding value; and 

means for not modifying a control signal from its immediately 
preceding value. 

4. The microprocessor of claim 3, wherein the controller further includes: 

means for setting a control signal to a data state. 

5. A method of updating a design of a semiconductor chip at a hardware 
design language level (HDL) of simulation, to maximize an amount of logic 
that can be set to a previous cycle state, comprising: 

automatically reading and setting a value of control signals on a per- 
cycle basis in a template and updating the HDL design with new data; 

changing a first predetermined value of the template to be set with the 
previous state of the control signal; and 

executing a test sweep to determine a "don't care" state of the control 

signals. 

6. The method according to claim 1, further determining which of the control 
signals are not to be modified for each instruction. 

7. The method according to claim 5, wherein said first predetermined value 
comprises a first non-zero value. 

8. The method according to claim 5, wherein said "don't care" state indicates 
a state at which a respective control signal of said control signals maintains a 
value from its previous cycle. 

9. A microcode unit in a microprocessor, for outputting control signals, for 
each of a plurality of instructions, required by said microprocessor for 
executing said instructions, the microcode unit comprising: 
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4 an instruction address input for receiving an instruction address; 

5 a control variable input for receiving a control variable corresponding 

6 to a current state of the microprocessor; 

7 a control signal input for receiving all the control signals output by the 

8 microcode unit for an immediately preceding instruction; and 

9 a plurality of embedded logic circuits each dedicated for evaluating 
10 one unique type of instruction received by the microcode unit. 

1 10. A microprocessor for a portable computer, for reducing power 

2 consumption, comprising: 

3 a plurality of microcode units, said microcode units for outputting 

4 control signals, for each of a plurality of instructions, required by said 

5 microprocessor for executing said instructions; 

6 means for maintaining selected control signals to values the same as in 

7 an immediately previous instruction cycle; and 

8 means for passing a control variable to one of the microcode units. 

1 11. The microprocessor of claim 10, further comprising embedded logic in the 

2 microcode units for testing for conditions of a respective opcode of an 

3 instruction. 

1 12. A microprocessor system for reducing power consumption, comprising: 

2 a plurality of microcode units each for receiving an instruction, each of 

3 said microcode units decoding said instruction to determine an instruction 

4 type, setting a value of each control signal within the microcode unit 

5 associated with the instruction, 

6 wherein values set are one of "0", "1", or maintaining a previous value, 

7 and 

8 wherein only control signals required for a function of an opcode of 

9 the instruction are changed, such that each opcode is a function of an 
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10 immediately previous opcode, wherein the control signals for each unit are 

1 1 changed only when their function interferes with the current opcode being 

12 executed, wherein embedded logic is included within the microcode and 

13 represents conditional checks for a particular opcode, where depending upon 

14 the value being set, the value is settable to different values; and 

15 a set of logic trees for recombining the control signals and performing 

16 a logic operation on the control signals to produce a single 

17 final control signal. 

1 13. The microprocessor according to claim 12, wherein the control signals are 

2 passed to the microcode unit are re-combined to form a single set of control 

3 signals, each of the microcode units have their own set of control signals. 

1 14. The microprocessor according to claim 12, further comprising a latch for 

2 latching a single final control signal. 

1 15. A method of reducing power in a portable microprocessor, including: 

2 obtaining an opcode group and obtaining a control signal therefrom; 

3 determining whether said control signal is active; 

4 if said control signal is determined to be active, setting the control 

5 signal to active; 

6 running a test case for the opcode group to determine whether the 

7 opcode passes; and 

8 if said opcode group passes, marking the control signal. 

1 16. The method according to claim 15, further including: 

2 determining whether any other control signals exist for the opcode 

3 group; 

4 when no more control signal exists, obtaining a next opcode group and 

5 testing and determining whether control signals of said next opcode should be 
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6 marked; and 

7 when no more opcode groups exist, setting all marked control signals 

8 to active and executing a regression analysis thereon. 

1 17. The method according to claim 16, further comprising: 

2 when said regression analysis fails, performing debugging; 

3 when said regression analysis passes, setting all marked signals to their 

4 previous states and executing another regression analysis thereon; 

5 when said another regression analysis fails, performing debugging; and 

6 when said another regression analysis passes, performing checking in 

7 the unit. 

1 18. A method of creating a state machine control logic for a microprocessor, 

2 comprising: 

3 providing a template for every function type within the 

4 microprocessor, said template being updated as s design specification on a 

5 per-cycle basis; 

6 at a first function boundary, reading a current functional template from 

7 a hardware design language level; 

8 obtaining a control signal from an opcode group, and determining 

9 whether the control signal is active; 

10 if the control signal is not active, obtaining a next control signal from 

11 the opcode group, and if the control signal is active, selecting a first non-zero 

12 value of the template and changing the first non-zero value to be set to the 

13 previous state of the control signal; 

14 searching a data base to locate all tests that have a function of said 

15 control signal and creating a test sweep; 

16 updating by a new template, a temporary copy of the updated 

1 7 microcode function block; 

18 running the test sweep with the previous state set for the one control 
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19 signal; and 

20 if the test sweep passes, marking the control bit as a potential "don't 

21 care" value. 

1 19. The method according to claim 18, further comprising: 

2 examining and processing each control signal, setting each one 

3 individually, and running a test sweep automatically, to maintain the control 

4 signals found to be "don't care" and not setting function-critical signals; 

5 after the template is fully swept on a per-bit basis and when all opcode 

6 groups are examined, setting all valid "don't care" bits; 

7 re-running the test sweep to ensure that there is no bit-to-bit 

8 interconnections; 

9 incrementing the function count , and creating a new template; finding 

10 tests, and completing analysis; 

1 1 upon the function count reaching a maximum value, every function 

12 type being updated with the previous control signal; 

13 executing all templates on the microcodes together with each other.; 

14 executing a full regression to ensure that the opcode function still 

15 functions with the automatically-generated "don't care" verilog, and 

16 performing debugging if the regression fails; 

17 if the full regression passes, then designating the new verilog as an 

18 official release design, and printing the templates in a readable format so that a 

19 complete documentation exists on a function-by-function basis of true "0s'\ 

20 true "Is", and previous "don't care" function on a bit-by -bit basis. 

1 20. A method of providing a state machine decoding, comprising: 

2 decoding a current opcode to provide a decode; 

3 setting required functions signals; 

4 setting exclusive functions outside of the current opcode to a previous 

5 state; and 
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6 latching results of the decode. 

1 21. A signal-bearing medium tangibly embodying a program of machine- 

2 readable instructions executed by an apparatus to perform a method of 

3 updating a design of a semiconductor chip at a hardware design language level 

4 (HDL) of simulation, to maximize an amount of logic that can be set to a 

5 previous cycle state, said method comprising: 

6 automatically reading and setting a value of control signals on a per- 

7 cycle basis in a template and updating the HDL design with new data; 

8 changing a first predetermined value of the template to be set with the 

9 previous state of the control signal; and 

10 executing a test sweep to determine a "don't care" state of the control 

1 1 signals. 

1 22. A signal-bearing medium tangibly embodying a program of machine- 

2 readable instructions executed by an apparatus to perform a method of 

3 reducing power in a portable microprocessor, said method including: 

4 obtaining an opcode group and obtaining a control signal therefrom; 

5 determining whether said control signal is active; 

6 if said control signal is determined to be active, setting the control 

7 signal to active; 

8 running a test case for the opcode group to determine whether the 

9 opcode passes; and 

10 if said opcode group passes, marking the control signal. 
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